热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

拓端tecdat|R语言提取时间序列的周期性成分应用EMD,小波滤波器,Baxter过滤器等

全文链接:http:tecdat.cn?p5399原文出处:拓端数据部落公众号介绍对商业周期的分析需要提取时间序列的周期性成分,该时间

 全文链接:http://tecdat.cn/?p=5399


原文出处:拓端数据部落公众号


介绍

对商业周期的分析需要提取时间序列的周期性成分,该时间序列通常也受到诸如潜在趋势或噪声等其他因素的影响。本文介绍了一些在最近的文献中用于从给定序列中提取商业周期的方法。它基于Stock and Watson(1999)在“宏观经济学手册”中关于商业周期的章节。我还介绍了相对较新的方法,如小波滤波器或经验模式分解。由于这篇文章的重点是在R中实现某些过滤技术,我不会涉及数学。相反,我将参考各自的文献。对于这些例子,我使用了实际GDP的季度数据。

names(gdp) <- c("Time","GDP") # 重命名gdp[,"GDP"] <- log(gdp[,"GDP"]) # 取对数

为了直观地了解提取时间序列的周期性成分意味着什么,请查看下图中随时间变化的对数实际GDP的发展情况。


ggplot(gdp,aes(x=Time,y=GDP)) + geom_line(size=.5) + theme_classic()

这种方法相对有争议,因为它假设存在一个恒定的线性时间趋势。正如我们上面所看到的,鉴于趋势增长率随时间的稳步下降,这种情况不太可能发生。然而,仍然可以假设时间趋势的不同函数形式,例如添加二次项,摆脱趋势。这种方法的另一个缺点是它只能排除趋势,而不能排除噪声,即序列中的非常小的波动。


差分

接下来的方法是采用一阶差分,因为它通常被教导以获得平稳的时间序列。这假设数据是不稳定的。取得一阶差分的结果显示在下图中,其中它也与时间趋势序列进行比较。差分数据在零线附近波动得更多,但它也包含很多噪声。

#可视化g <- melt(dat,,na.rm=TRUE)# 定义绘图函数plotaxis.line=element_line(size=.3,colour="black"), # 设置绘图参数# 绘图plot.cycles(d=g)

Hodrick Prescott过滤器

Hodrick和Prescott(1981)开发了一种滤波器,它将时间序列分为趋势,周期和噪声分量。需要时间序列和平滑参数。下图显示了Hodrick-Prescott滤波器获得的实际GDP的周期性成分值,并将其与线性去趋势序列的值进行了比较。两个序列的行为看起来非常相似,只是HP序列在零附近波动较大,而线性去趋势序列仍然包含趋势的成分。此外,循环HP序列还包括一些类似噪音的成分

#绘图g <- melt(dat[,c(1,4,3)],id.vars="Time",na.rm=TRUE)plot(g)


Baxter过滤器

Baxter和King(1994,1999)提出了一种滤波器,它可以生成与HP滤波器类似的结果,但它可以剔除上面显示的许多类似噪声的行为。它需要序列,周期数量的下限和上限,假定周期发生(plpu),以及平滑因子nfix。文献(参见NBER,Stock和Watson(1999))表明商业周期持续6至32个月。这些值用于指定循环周期的下限和上限。BK滤波器的结果如下图所示。该方法的一个相对序列的缺点是平滑因子导致在序列的开始和结束时样本的丢失。这可能是小样本的问题。

# 绘图dat <- cbind(dat,data.frame( bk))g <- melt(dat[,c(1,5,4)], ,na.rm=TRUE)plot(g )


小波滤波器

Yogo(2008)提出使用小波滤波器从时间序列数据中提取商业周期。这种方法的优点是该功能不仅可以提取序列的趋势,周期和噪声,而且可以更加具体地说明周期发生的周期。然而,由于该方法只能捕获2的幂的周期性,即2,4,8,16,32等,所以没有完全的自由度。

R中的方法实现也很简洁,但在使用之前需要一些额外的数据转换。它需要时间序列的不同版本和分解的深度。

该函数给出了多个序列,必须将它们累积起来cumsum,将它们转换回反映周期性模式的数据。此外,一些序列可以结合使用rowSums。当应该一起分析持续8到16和16到32个周期的周期时,这很有用,如下图所示。小波滤波器产生与BK滤波器类似的结果,因为循环周期的上限在两者中相等,下限仅相差2。

#绘图g <- melt(dat[,c(1,6,5)],id.vars="Time",na.rm=TRUE)levels(g[,2]) <- c("Wavelet","Baxter King")plot.cycles(g,"Wavelet vs. Baxter King")


经验模式分解(EMD)

基于Huang等人。(1998)Kozic和Sever(2014)提出经验模式分解作为商业周期提取的另一种方法。它需要不同的时间序列,边界条件和规则,该规则指定迭代过程在哪个点获得了满意的结果并且可以停止。该滤波器方法的结果与HP,BK和小波滤波器相比有所不同。

 emd <- as.data.frame(emd(xt=diff(gdp[,2]),boundary="wave",stoprule="type2")$imf)g <- melt(dat[,c(1,7,4)],id.vars="Time",na.rm=TRUE)plot.cycles(g,"EMD vs. Hodrick Prescott")

 



最受欢迎的见解

1.在python中使用lstm和pytorch进行时间序列预测

2.python中利用长短期记忆模型lstm进行时间序列预测分析

3.使用r语言进行时间序列(arima,指数平滑)分析

4.r语言多元copula-garch-模型时间序列预测

5.r语言copulas和金融时间序列案例

6.使用r语言随机波动模型sv处理时间序列中的随机波动

7.r语言时间序列tar阈值自回归模型

8.r语言k-shape时间序列聚类方法对股票价格时间序列聚类

9.python3用arima模型进行时间序列预测


推荐阅读
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 本文详细介绍 Go+ 编程语言中的上下文处理机制,涵盖其基本概念、关键方法及应用场景。Go+ 是一门结合了 Go 的高效工程开发特性和 Python 数据科学功能的编程语言。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 本文详细介绍了如何在BackTrack 5中配置和启动SSH服务,确保其正常运行,并通过Windows系统成功连接。涵盖了必要的密钥生成步骤及常见问题解决方法。 ... [详细]
  • This guide provides a comprehensive step-by-step approach to successfully installing the MongoDB PHP driver on XAMPP for macOS, ensuring a smooth and efficient setup process. ... [详细]
  • 探讨如何高效使用FastJSON进行JSON数据解析,特别是从复杂嵌套结构中提取特定字段值的方法。 ... [详细]
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文介绍了在使用Visual Studio 2015进行项目开发时,遇到类向导弹出“异常来自 HRESULT:0x8CE0000B”错误的解决方案。通过具体步骤和实践经验,帮助开发者快速排查并解决问题。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 创建第一个 MUI 移动应用项目
    本文将详细介绍如何使用 HBuilder 创建并运行一个基于 MUI 框架的移动应用项目。我们将逐步引导您完成项目的搭建、代码编写以及真机调试,帮助您快速入门移动应用开发。 ... [详细]
author-avatar
手机用户2502940417_253
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有